package com.sugon.dao;

import com.sugon.entity.DevAmTicketItemEntity;
import com.sugon.modules.device.model.vo.DevMaintenanceTicketItemDetailVO;
import org.apache.ibatis.annotations.Delete;
import org.apache.ibatis.annotations.Param;

import java.util.List;
import java.util.Map;

/**
 * 设备自主维护工单项Dao
 *
 * @author YuXD
 * @date 2023-01-23
 */
public interface DevAmTicketItemDao extends BaseDao<DevAmTicketItemEntity> {

    /**
     * 罗列出临时维护工单明细项列表
     *
     * @param ticketId 工单ID
     * @return
     */
    List<Map<String, Object>> listTemTicketItems(@Param("ticketId") String ticketId);

    /**
     * 罗列出临时维护工单明细项列表
     *
     * @param ticketId 工单ID
     * @return
     */
    List<Map<String, Object>> listPlanTicketItems(@Param("ticketId") String ticketId);

    /**
     * 查询所有
     *
     * @param param
     * @return
     */
    List<DevMaintenanceTicketItemDetailVO> queryAll(Map<String, Object> param);

    /**
     * 统计工单维护项数目
     *
     * @param devMaintenanceTicketId 设备维护工单ID
     * @param status                 状态，已完成 未完成
     * @return
     */
    int countTicketOptionNum(@Param("devMaintenanceTicketId") String devMaintenanceTicketId, @Param("statusArray") Integer... status);

    /**
     * 删除指定维护工单下的设备维护项
     *
     * @param ticketId 维护工单ID
     * @return
     */
    @Delete("DELETE FROM DEV_MAINTENANCE_TICKET_ITEM_AM WHERE DEV_MAIN_TICKET_ID = #{ticketId}")
    int deleteByTicketId(@Param("ticketId") String ticketId);

    /**
     * 进行设备AM工单数分布统计
     * 两个维度：月度和周次
     * 参数中需要包含以下几个参数
     * statStartDate 统计起始时间
     * statEndDate 统计结束时间
     * dimension 维度 MONTHLY or WEEKLY
     *
     * @return
     */
    List<Map<String, Object>> doDevAmTicketItemDistributionNumStat(Map<String, Object> param);

}
